package com.mlick.a.leetcode;

/**
 * 344. 反转字符串
 * 编写一个函数，其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
 * <p>
 * 不要给另外的数组分配额外的空间，你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
 * <p>
 *  
 * <p>
 * 示例 1：
 * <p>
 * 输入：s = ['h','e','l','l','o']
 * 输出：['o','l','l','e','h']
 * 示例 2：
 * <p>
 * 输入：s = ['H','a','n','n','a','h']
 * 输出：['h','a','n','n','a','H']
 *  
 * <p>
 * 提示：
 * <p>
 * 1 <= s.length <= 105
 * s[i] 都是 ASCII 码表中的可打印字符
 * <p>
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode.cn/problems/reverse-string
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
public class A344 {

    /**
     * 自己的解题思路
     * 双指针法，前后指针移动，并交换
     */
    static class Solution {
        public void reverseString(char[] s) {
            if (s == null || s.length == 0) {
                return;
            }

            int r = s.length-1;
            for (int i = 0; i < s.length; i++, r--) {
                if (i >= r) {
                    break;
                }
                char temp = s[i];
                s[i] = s[r];
                s[r] = temp;
            }

            // System.out.println(s);
        }
    }

    public static void main(String[] args) {
        // new Solution().reverseString(new char[]{'h', 'e', 'l', 'l', 'o'});
        new Solution().reverseString(new char[]{'h', 'e', 'l', 'l'});
        new Solution().reverseString(new char[]{'h', 'e', 'l'});
        // new Solution().reverseString(new char[]{'h', 'e'});
        // new Solution().reverseString(new char[]{'o'});
    }
}
